so 
= a> 
s a> 
= at 

|c 



IN THE UNITED STATES PATENT AND TRADEMARK OFFICE 
UTILITY PATENT APPLICATION TRANSMITTAL 
UNDER 37 CFR 1.53(b) 



J0_ — 1 

^Address to: 


Attorney Docket No. 


STL9-2000-0080US1 


o 


Box Patent Application 


Inventor(s) 


Curt L. Cotner, et al. 




Assistant Commissioner for Patents 


Express Mail Label No, 


EL290558674US 


— j s{ 


Washington, DC 20231 


Filing Date 


September 27, 2000 


u s 

■n p 



Title of Application; Method of, System for, and Computer Program Product for Providing Automatic 
Identification of a Computer Program Code Candidate for Web Deployment or a Stored Procedure 

Transmitted with the patent application are the following: 

23 Page(s) Specification, Claims and Abstract 

6 Page(s) J A Formal drawings 

3 Page(s) Declaration and Power of Attorney (unsigned) 

_ Page(s) Assignment of the Invention to International Business Machines Corporation 

_2_ Page(s) Information Disclosure Statement (IDS/PTO 1 449) (copies of citations not included in number of pages) 

x Copies of IDS citations 

jc_ Return Receipt Postcard (MPEP 503). 



Wee Calculation: 





Claims 




Extra 


Rate 


Fees 


Basic Fee 










$690.00 


Total Claims 


24 


-20 = 


4 


x $18.00 


$ 72.00 


Independent Claims 


3 


-3 = 


0 


x $78.00 




Multivle Devdendent Claims 








+$260.00 










TOTAL 


$762.00 



X Please charge my Deposit Account No. 09-0460 in the amount of $ 762.00 . 
?sal _X_The Commissioner is hereby authorized to charge payment of the following fees 
overpayment to Deposit Accoun t 09-0460 . A duplicate copy of this sheet is 
X Any filing fees under 37 CFR 1 A 6 for the presentation of extra claims. 
X Any patent application processing fees under 37 CFR 1.17. 

EXPRESS MAIL CERTIFICATE 

I hereby certify that the above paper/fee is being deposited 
with the United States Postal Service "Express Mail Post Office to Addressee" 
service under 37 CFR 1 . 10 on the date indicated below and is addressed 
to the Assistant Commissioner for Patents, Washington, DC 2023 1 . 

Date of Deposit: September 27, 2000 

Person Mailing paper/fee: Jeanette Berry Durbin 

Signature 



A duplicate copy of this sheet is attached. 

associated with this communication or credit any 
attached. 



Respectfully submitted 
Curl Cotner et al. 





Prentiss W y 

Registration No.' #33,123 
Attorney for Applicant(s) 
Telephone (408) 463-5673 
IBM Corporation 
Intellectual Property Law 
555 Bailey Avenue (J46/G467) 
San Jose, CA 95141-1003 



Express mail Label #: EL290558674US 



SPECIFICATION 



IBM Docket No. STL9-2000-0080US1 



TO ALL WHOM IT MAY CONCERN: 

BE IT KNOWN that We, Curt L. Cotner of Gilroy, California and citizen of the United States, 
Laurence E. England of Morgan Hill, California and citizen of the United States, Howard J. 
Glaser of San Jose, California and citizen of the United States, and Howard M. Hess of 
Evanston, Illinois and citizen of the United States have invented new and useful improvements 
in 



METHOD OF, SYSTEM FOR, AND COMPUTER PROGRAM PRODUCT FOR 
PROVIDING AUTOMATIC IDENTIFICATION OF A COMPUTER PROGRAM 
CODE CANDIDATE FOR WEB DEPLOYMENT OR A STORED PROCEDURE 

of which the following is a specification: 
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METHOD OF, SYSTEM FOR, AND COMPUTER PROGRAM PRODUCT FOR 
PROVIDING AUTOMATIC IDENTIFICATION OF A COMPUTER PROGRAM 
CODE CANDIDATE FOR WEB DEPLOYMENT OR A STORED PROCEDURE 



A portion of the Disclosure of this patent document contains material which is subject 
to copyright protection. The copyright owner has no objection to the facsimile reproduction by 
anyone of the patent document or the patent disclosure, as it appears in the Patent and 
Trademark Office patent file or records, but otherwise reserves all copyright rights whatsoever. 
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1 BACKGROUND OF THE INVENTION 

2 
3 

4 1. Field of the Invention 

5 

6 The present invention relates in general to software re-engineering, and more 

7 particularly to identifying computer program code which is a candidate for Web enablement or 

8 stored procedures. 
9 

10 

1 1 2. Description of the Related Art 

12 

13 A large enterprise may have a significant volume of computer application code, the 

14 enterprise's code inventory. Yet the enterprise's programming skill base to maintain, manage, 

15 enhance, or re-implement that code inventory may be dwindling. Relative to re- 

16 implementation, not all application programs are candidates for conversion to a Web interface 

17 or a database stored procedure. Many, if not most, applications do not possess the necessary 

1 8 characteristics for such a conversion. Discovering those existing opportunities to easily access 

19 a function from the Web or convert a function to a database stored procedure may be difficult 

20 due to the labor intensive nature of the conventional manual techniques. Conventional 

21 methods have failed to provide adequate solutions to these problems. Thus, there is a clearly 

22 felt need for a method of, system for, article of manufacture for, and computer program product 

23 for identifying computer program code which is a candidate for Web enablement or stored 

24 procedures. 
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1 SUMMARY OF THE INVENTION 

2 

3 The present invention comprises a method, system, computer program product, and 

4 article of manufacture for identifying computer program code which is a candidate for Web 

5 enablement or stored procedures. Source code corresponding to computer program code is 

6 scanned and parsed to determine static information concerning the computer program code. 

7 The static information is stored in a database. Dynamic information concerning the computer 

8 program code during an execution of the computer program code is also collected and stored in 

9 the database. Responsive to the static information and dynamic information stored in the 

10 database, relationships and dependencies are then developed and stored in the database. The 

1 1 database may then be queried to produce a set of potential candidates of computer program 

12 code meeting a constraint of the query. If insufficient candidates are returned by the query, 
1 3fl then the query constraint may be relaxed, and the query repeated. 

i4;j 

lfO A candidate for re-implementation as a database stored procedure call may be identified 

16kj by a query searching the database for a portion of the computer program code having static 

lf j information indicating that the portion of the computer program code contains a number, above 

1 £) a specified first threshold, of calls to a database management system, and having dynamic 

l|u information indicating that the portion of the computer program code is subject to a number of 

2(£{ calls, above a specified second threshold, by another portion of computer program code. 
20 

22 A candidate for re-implementation as a Web-enabling interface call may be identified 

23 by a query searching the database for a portion of the computer program code having static 

24 information indicating that the portion of the computer program contains a transaction and does 

25 not contain screen output related program code. 
26 

27 The placement of this information capture, classification, and relationship/dependency 

28 discovery into a database , the Application Knowledge Base, that can be queried may provide 

29 significant advantages to a user. For an enterprise, this process may be performed across the 
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1 entire enterprise, encompassing all of the enterprise's inventory of application programs. The 

2 details of the enterprise's application program inventory may be saved and queried in the 

3 application knowledge base. These details may include system and sub-system specific 

4 information. In addition to queries for identification of candidate computer code, the 

5 application knowledge base may simply be queried for application characteristics. 
6 

7 Unlike simple conventional string matching or pattern matching approaches, the present 

8 invention discovers relationships and dependencies within the computer program code. For 

9 example, a COBOL dynamic CALL holding the called routine's name in a variable may be 

10 analyzed by data flow analysis to determine the potential values of the target called routine. 

1 1 Dynamic information obtained during the execution of the COBOL dynamic CALL may 

12 augment the static information obtained through the static analysis and data flow analysis. 

13 J 

14pJ One aspect of a preferred embodiment of the present invention identifies computer 

15hI program code which is a candidate meeting a query constraint. 

iij 

17^ Another aspect of a preferred embodiment of the present invention identifies computer 

180 program code which is a candidate for a stored procedure. 

19 i3 

2Q^f Another aspect of a preferred embodiment of the present invention identifies computer 

2 IS program code which is a candidate for Web enablement. 

22 

23 Another aspect of a preferred embodiment of the present invention scans and parses 

24 source code corresponding to computer program code to determine static information 

25 concerning the computer program code, and stores the static information in a database. 
26 

27 Another aspect of a preferred embodiment of the present invention collects dynamic 

28 information concerning the computer program code during an execution of the computer 

29 program code, and stores the dynamic information in the database. 
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Another aspect of a preferred embodiment of the present invention discovers or 
develops relationships and dependencies responsive to the static information and dynamic 
information stored in the database, and stores the relationships and dependencies in the 
database. 

Another aspect of a preferred embodiment of the present invention queries the database 
to produce a set of potential candidates of computer program code meeting a constraint of the 
query. If insufficient candidates are returned by the query, then the query constraint may be 
relaxed, and the query repeated. 

Another aspect of a preferred embodiment of the present invention identifies a 
candidate for re-implementation as a database stored procedure call by a query searching the 
database for a portion of the computer program code having static information indicating that 
the portion of the computer program code contains a number, above a specified first threshold, 
of calls to a database management system, and having dynamic information indicating that the 
portion of the computer program code is subject to a number of calls, above a specified second 
threshold, by another portion of computer program code. 

Another aspect of a preferred embodiment of the present invention identifies a 
candidate for re-implementation as a Web-enabling interface call by a query searching the 
database for a portion of the computer program code having static information indicating that 
the portion of the computer program contains a transaction and does not contain screen output 
related program code. 
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1 A preferred embodiment of the present invention has the advantage of promoting reuse 

2 of an existing application program's business logic, resources, or other assets. 
3 

4 A preferred embodiment of the present invention has the advantage of promoting 

5 impact analysis and application understanding of an existing application program. 
6 

7 A preferred embodiment of the present invention has the further advantage of 

8 promoting reuse of an existing application program's business logic to link the existing 

9 business logic with the Web via a connector to form a new Web application program. 
10 

1 1 A preferred embodiment of the present invention has the further advantage of providing 

12 improved analysis, identification, and isolation of the business logic of an application program. 

A preferred embodiment of the present invention has the further advantage of reducing 

lSlj or eliminating labor intensive efforts in the creation of a Web connector through the analysis, 

ld~ = identification, and isolation of the business logic. 

ijM 

183 A preferred embodiment of the present invention has the further advantage of 

l^Jt promoting the use of an enterprise's existing programming skills. 

2(N 

2 S3 A preferred embodiment of the present invention has the further advantage of providing 

22 an application knowledge base, a database containing static information, dynamic information, 

23 and relationships and dependencies of computer program code, which may be queried to 

24 identify candidate computer program code. 
25 

26 A preferred embodiment of the present invention has the further advantage of providing 

27 identification of computer program code which is a candidate for stored procedures. 
28 

29 A preferred embodiment of the present invention has the further advantage of providing 
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1 identification of computer program code which is a candidate for Web enablement. 
2 

3 A preferred embodiment of the present invention has the further advantage of providing 

4 an improved user interface for identification of computer program code which is a candidate 

5 for Web enablement or stored procedures. 
6 

7 A preferred embodiment of the present invention has the further advantage of providing 

8 improved usability in a tool for identification of computer program code which is a candidate 

9 for Web enablement or stored procedures. 
10 

1 1 A preferred embodiment of the present invention has the further advantage of providing 

12 improved functionality in a tool for identification of computer program code which is a 
ift candidate for Web enablement or stored procedures. 
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I BRIEF DESCRIPTION OF THE DRAWINGS 

2 

3 For a more complete understanding of the present invention and the advantages thereof, 

4 reference is now made to the Description of the Preferred Embodiment in conjunction with the 

5 attached Drawings, in which: 
6 

7 Figure 1 is a block diagram of a distributed computer system used in performing the 

8 method of the present invention, forming part of the apparatus and computer program product 

9 of the present invention, and which may use the article of manufacture and computer program 
1 0 product comprising a computer-readable storage medium having a computer program 

I I embodied in said medium which may cause the computer system to practice the present 
12 invention; 

iij 

l4?'! Figure 2 is a block diagram of a preferred embodiment of the present invention; 
lfu 

1 S Figure 3 illustrates a preferred embodiment of the static scanner or parser portion of the 

it y preferred embodiment of the present invention; 

IP 

1 J! Figure 4 illustrates a preferred embodiment of the dynamic scanner or execution 

20=! monitor parser portion of the preferred embodiment of the present invention; 

2P 

22 Figure 5 illustrates a preferred embodiment of the relationship analyzer portion of the 

23 preferred embodiment of the present invention; and 
24 

25 Figure 6 is a flowchart illustrating the operations preferred in carrying out the preferred 

26 embodiment of the present invention. 
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1 DESCRIPTION OF THE PREFERRED EMBODIMENT 

2 

3 An embodiment of the invention is now described with reference to the figures where 

4 like reference numbers indicate identical or functionally similar elements. Also in the figures, 

5 the left most digit of each reference number corresponds to the figure in which the reference 

6 number is first used. While specific configurations and arrangements are discussed, it should 

7 be understood that this is done for illustrative purposes only. A person skilled in the relevant art 

8 will recognize that other configurations and arrangements can be used without departing from 

9 the spirit and scope of the invention. It will be apparent to a person skilled in the relevant art 
10 that this invention can also be employed in a variety of other devices and applications. 

11 

12 Referring first to Figure 1, there is depicted a graphical representation of a data 

l|i processing system 8, which may be utilized to implement the present invention. As may be 

ill seen, data processing system 8 may include a plurality of networks, such as Local Area 

1 JU Networks (LAN) 10 and 32, each of which preferably includes a plurality of individual 

l5 computers 12 and 30, respectively. Alternatively, networks 10 and 32 may be intranets or 

if 1 portions of the internet. Of course, those skilled in the art will appreciate that a plurality of 

llP Intelligent Work Stations (IWS) coupled to a host processor may be utilized for each such 

lS network. Each said network may also consist of a plurality of processors coupled via a 

2pj communications medium, such as shared memory, shared storage, or an interconnection 

2P network. As is common in such data processing systems, each individual computer may be 

22 coupled to a storage device 14 and/or a printer/output device 16 and may be provided with a 

23 pointing device such as a mouse 17. 
24 

25 The data processing system 8 may also include multiple mainframe computers, such as 

26 mainframe computer 18, which may be preferably coupled to LAN 10 by means of 

27 communications link 22. The mainframe computer 18 may also be coupled to a storage device 

28 20 which may serve as remote storage for LAN 10. Similarly, LAN 10 may be coupled via 

29 communications link 24 through a sub-system control unit/communications controller 26 and 
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1 communications link 34 to a gateway server 28. The gateway server 28 may be an IWS which 

2 serves to link LAN 32 to LAN 10. Preferably, server 28 is a web application server which 

3 passes transactions from a requester 30 on the internet 32 to the mainframe 18 upon which a 

4 back-end application serving the transaction is executing. 
5 

6 With respect to LAN 32 and LAN 10, a plurality of documents or resource objects may 

7 be stored within storage device 20 and controlled by mainframe computer 18, as resource 

8 manager or library service for the resource objects thus stored. Of course, those skilled in the 

9 art will appreciate that mainframe computer 18 may be located a great geographic distance 

10 from LAN 10 and similarly, LAN 10 may be located a substantial distance from LAN 32. For 

1 1 example, LAN 32 may be located in California while LAN 10 may be located within North 
1 %_ Carolina and mainframe computer 18 may be located in New York. 

130 

14T I Software program code which employs the present invention is typically stored in the 

1 memory of a storage device 14 of a stand alone workstation or LAN server from which a 

l&l developer may access the code for distribution purposes, the software program code may be 

li U embodied on any of a variety of known media for use with a data processing system such as a 

lfi diskette or CD-ROM or may be distributed to users from a memory of one computer system 

1 £J over a network of some type to other computer systems for use by users of such other systems. 

2pJ Such techniques and methods for embodying software code on media and/or distributing 

2? software code are well-known and will not be further discussed herein. 
22 

23 As will be appreciated upon reference to the foregoing, it is often desirable for a user 

24 to link an application program on the mainframe 18 to the internet 32 and/or World Wide Web 

25 (Web), where the application program was not originally designed for Web or internet based 

26 transactions. For such Web-enablement, the user needs to identify call interfaces of the 

27 application program which conventionally is a manual process. If this application program has 

28 a database dependency, then it may also be desirable for this user to identify call interfaces or 

29 computer program code which may be re-implemented as a database stored procedure call. A 
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1 preferred embodiment of the present invention assists a user in performing such an 

2 identification of computer program code which is a candidate for a particular purpose, such as 

3 re-implementation. Alternative embodiments identify candidates for re-implementation such as 

4 Web enablement or a stored procedure. 
5 

6 Referring now to Figure 2 illustrating a block diagram of a preferred embodiment of 

7 the present invention, the preferred embodiment comprises a database 215 (Application 

8 Knowledge Base) for storing static information 220, dynamic information 225, and 

9 relationships and dependencies 250 corresponding to computer code in application inventory 

10 205. The database in the preferred embodiment is an IBM® DB2® UDB (Universal 

1 1 Database); however, other relational or non-relational (object, network, hierarchal, flat, . . .) 

12 databases may be used in addition to either persistent or in-memory databases without 

1 |p departing from the spirit and scope of the present invention. (IBM® and DB2® are registered 

li J trademarks of International Business Machines Corporation in the United States, other 

if U countries, or both.) The static information 220 concerning the computer program code 205 is 

16 j determined by a scanner, parser, or other software analysis tool 210. An execution monitor or 

1J J scanner 230 collects dynamic information 225 concerning the computer program code 205 

1 § during an execution 235 of the computer program code. The static information 220 and the 

lftj dynamic information 225 are analyzed by an relationship analyzer 245 to discover and/or 

2fi develop relationships and dependencies 250 responsive to the static information 220 and 

2p dynamic information 225. A query 255 of the Application Knowledge Base 215 may then 

22 produce a set of potential candidates 260 of computer program code meeting a constraint of the 

23 query. The query facility of the preferred embodiment is IBM net.Data, a dynamic HTML 

24 (HyperText Markup Language) page generator; however, other query facilities may be used 

25 such as a Java servlet or a Java data bean. (Java and all Java-based trademarks are trademarks 

26 of Sun Microsystems, Inc. in the United States, other countries, or both.) 
27 

28 Figure 3 illustrates a preferred embodiment 300 of the static scanner, parser, or other 

29 analysis tool 210 which collects the static information 220 concerning the computer program 
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1 code 205. The static scanner 300 may comprise multiple static analysis tools. In the preferred 

2 embodiment, the static scanner 300 comprises a control/environment parsing tool 305, a 

3 transaction parsing tool 310, a program source parsing tool 315, a database parsing tool 320, 

4 and an executable/ load module parsing tool 325, The preferred control/environment parsing 

5 tool 305 is a JCL (Job Control Language) parsing tool which analyzes JCL 330 to provide 

6 program execution, dataset creation and use, and database use 335. An IBM Customer 

7 Information Control System (CICS®) parsing tool and an IBM Information Management 

8 System (MS) parsing tool are preferred transaction parsing tools 310 providing program 

9 execution, dataset and database use 340 from analyzing transaction definitions and file 

10 definitions 345. (CICS® is a registered trademark of International Business Machines 

1 1 Corporation in the United States, other countries, or both.) Application program source 350 
12*6 may be analyzed by the program source parsing tool 315 to provide data record definitions, 
13B data store I/O, call relationships, and data element use 355. A database parsing tool for IMS 
14| DBD (Data Base Definition) and IMS PSB (Program Specification Block) and a database 
lS: parsing tool to analyze DB2 table information are preferred for the database parsing tool 320 
\& which analyzes database definitions 360 to provide linkages 365 between the application 

17 program source and databases such as MS, PSB, and DB2 among others. The executable/load 

ljfl module parsing tool 325 analyzes load modules 370 to provide module, CSECT (control 

ljpf section), translator, and translation date 375. 
2jQj 

2F Figure 4 illustrates a preferred embodiment 400 of the execution monitor or dynamic 

22 scanner 230 which collects dynamic information 225 concerning the computer program code 

23 205 during an execution 235 of the computer program code. The dynamic scanner 400 may 

24 also comprise multiple dynamic analysis tools, comprising in the preferred embodiment 

25 a coverage and performance measurement tool 410 and an inter-dependency tool 420. The 

26 coverage and performance measurement tool 410 analyzes the execution 430 of an application 

27 program run unit and compilation unit to determine the coverage for single or multiple test 

28 cases 440 and to measure performance 450. A preferred inter-dependency tool 420 is a CICS 

29 Inter-dependencies Utility which dynamically captures resource usage, transaction flow 460 
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1 from a CICS region 470. The execution monitor in the preferred embodiment is an IBM 

2 CICS Affinities Utility and the IBM CICS Interdependency Utility; however, those skilled in 

3 the art will recognize other execution monitors may be used without departing from the spirit 

4 and scope of the invention. 
5 

6 Figure 5 illustrates a preferred embodiment 500 of the relationship analyzer 245 which 

7 discovers and/or develops relationships and dependencies 250 responsive to the static 

8 information 220 and dynamic information 225. In the preferred embodiment, the relationship 

9 analyzer 500 provides automatic, generalized, inter-relationship analysis by performing 

10 IMS DL/I (Information Management System Data Language 1) call parameter analysis 510, 

1 1 call hierarchy expansion 520, load module to source relationship mapping 530, CICS 

12 pseudo-conversation flow analysis 540, missing and duplicate component analysis 550, and un- 
13S referenced component analysis 560. 

if: 

151} Referring now to Figure 6, the flowchart illustrates the operations preferred in carrying 

lLj out the preferred embodiment of the present invention. In the flowcharts, the graphical 

lf J conventions of a diamond for a test or decision and a rectangle for a process or function are 

lfi used. These conventions are well understood by those skilled in the art, and the flowcharts are 

lfn sufficient to enable one of ordinary skill to write code in any suitable computer programming 

2QS language. The process 600 of identifying computer program code which is a candidate for a 

2P particular purpose, such as re-implementation for Web enablement or stored procedures begins 

22 at process block 605. Process block 610 then uses static scanner 210 to scan or parse the 

23 application inventory 205 retaining static information 220 concerning the artifacts of the 

24 application program. Thereafter, process block 615 stores the static information 220 in the 

25 Application Knowledge Base 215. Process block 620 augments the Application Knowledge 

26 Base 215 with dynamic information 225 obtained by an execution scanner or monitor 230 

27 which collects the dynamic information 225 during the execution of an application program 

28 executable 235 produced by an assembler, compiler, or interpreter 240 from the computer 

29 program source code. After collection of the static information 220 and dynamic information 
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1 225, process block 625 uses relationship analyzer 245 to discover and develop relationships 

2 and dependencies 250 within the Application Knowledge Base 215, and then stores these 

3 relationships and dependencies 250 in the Application Knowledge Base 215. Thereafter, 

4 process block 630 may query 255 the application knowledge base 215 to produce a set of 

5 potential candidates 260 of computer program code meeting a constraint of the query. 
6 

7 For example, to determine which applications may benefit by being re-implemented as 

8 a database stored procedure, the query may search for routines containing SQL (Structured 

9 Query Language) statements that are the targets of a number of CALLs where the number is 

10 above a specified threshold. Thus the present invention provides a capability of identifying 

1 1 more likely candidates as opposed to the conventional manual process of looking for routines 
12L that contain a large amount of SQL. To determine which application programs are candidates 
IS for a Web interface under CICS, the query may search for CICS transactions that contain a 
llj COMMAREA (communication area) linkage and that are void of BMS (Basic Mapping 

l$ y Support) MAP send and/or receive statements (i.e., that lack screen I/O (input output)). 
15! 

iT After the results of the query are returned, decision block 635 determines if sufficient 

ife candidates are identified and returned. If a sufficient number of candidates are not discovered, 

lftj then process block 645 allows relaxing the query constraints, after which control returns to 

20] process block 630 to query the application knowledge base 215 with the relaxed constraints. 

22 Returning now to decision block 635, if sufficient candidates are identified, the process 

23 may end at process block 640. 
24 

25 Using the foregoing specification, the invention may be implemented using standard 

26 programming and/or engineering techniques using computer programming software, firmware, 

27 hardware or any combination or sub-combination thereof. Any such resulting program(s), 

28 having computer readable program code means, may be embodied within one or more 

29 computer usable media such as fixed (hard) drives, disk, diskettes, optical disks, magnetic tape, 
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1 semiconductor memories such as Read-Only Memory (ROM), Programmable Read-Only 

2 Memory (PROM), etc., or any memory or transmitting device, thereby making a computer 

3 program product, i.e., an article of manufacture, according to the invention. The article of 

4 manufacture containing the computer programming code may be made and/or used by 

5 executing the code directly or indirectly from one medium, by copying the code from one 

6 medium to another medium, or by transmitting the code over a network. An apparatus for 

7 making, using, or selling the invention may be one or more processing systems including, but 

8 not limited to, central processing unit (CPU), memory, storage devices, communication links, 

9 communication devices, servers, input/output (I/O) devices, or any sub-components or 

10 individual parts of one or more processing systems, including software, firmware, hardware or 

1 1 any combination or sub-combination thereof, which embody the invention as set forth in the 

12 claims. 

lj! 

l|P User input may be received from the keyboard, mouse, pen, voice, touch screen, or any 

1SU other means by which a human can input data to a computer, including through other programs 

llj such as application programs. 

iW 

Igj One skilled in the art of computer science will easily be able to combine the software 

1 tj created as described with appropriate general purpose or special purpose computer hardware to 

2(1! create a computer system and/or computer sub-components embodying the invention and to 

20 create a computer system and/or computer sub-components for carrying out the method of the 

22 invention. Although the present invention has been particularly shown and described with 

23 reference to a preferred embodiment, it should be apparent that modifications and adaptations 

24 to that embodiment may occur to one skilled in the art without departing from the spirit or 

25 scope of the present invention as set forth in the following claims. 



STL9-2000-0080US1 



We claim: 



CLAIMS 



1 . A method of identifying a portion of computer program code as a candidate for a 
modification, said method comprising the steps of : 

scanning and parsing source code corresponding to the computer program code 
to determine static information concerning the computer program code; 
storing the static information in a database; 

collecting dynamic information concerning the computer program code during 
an execution of the computer program code; 

storing the dynamic information in the database; 

developing relationships and dependencies responsive to the static information 

and dynamic information stored in database; 

storing the relationships and dependencies in the database; and 

providing for a query of the database to produce a set of potential candidates of 

computer program code meeting a constraint of the query. 

2. The method of claim 1 wherein if insufficient candidates are returned by the query, then 
providing for a relaxing of the constraint, and a repetition of the query. 

3. The method of claim 2 further comprising the step of identifying a portion of the 
computer program code as a candidate for re-implementation as a database stored procedure 
call 
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1 4. The method of claim 3 wherein the query searches the database for a portion of the 

2 computer program code having static information indicating that the portion of the computer 

3 program code contains a call to a database management system, and having dynamic 

4 information indicating that the portion of the computer program code is subject to a call by 

5 another portion of computer program code, 

1 5. The method of claim 4 wherein the query searches the database for a portion of the 

2 computer program code having static information indicating that the portion of the computer 

3 program code contains a number, above a specified first threshold, of calls to a database 

4 management system, and having dynamic information indicating that the portion of the 

5 computer program code is subject to a number of calls, above a specified second threshold, by 
ft another portion of computer program code. 

if 6. The method of claim 2 further comprising the step of identifying a portion of the 

W computer program code as a candidate for re-implementation as a Web-enabling interface call. 

i't I 

J;f 7. The method of claim 6 wherein the query searches the database for a portion of the 

S3 computer program code having static information indicating that the portion of the computer 

3 program code contains a transaction call. 

1 8. The method of claim 7 wherein the query also searches the database for a portion of the 

2 computer program code having static information indicating that the portion of the computer 

3 program does not contain screen output related program code. 
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1 9. An article of manufacture for use in a computer system for identifying a portion of 

2 computer program code as a candidate for a modification, said article of manufacture 

3 comprising a computer-readable storage medium having a computer program embodied in said 

4 medium which causes the computer system to execute a method comprising the steps of: 

5 scanning and parsing source code corresponding to the computer program code 

6 to determine static information concerning the computer program code; 

7 storing the static information in a database; 

8 collecting dynamic information concerning the computer program code during 

9 an execution of the computer program code; 

10 storing the dynamic information in the database; 

1 1 developing relationships and dependencies responsive to the static information 

12 and dynamic information stored in database; 

1 m storing the relationships and dependencies in the database; and 

l| ! providing for a query of the database to produce a set of potential candidates of 

fsM computer program code meeting a constraint of the query. 

V 10. The article of manufacture of claim 9 wherein if insufficient candidates are returned by 

||| the query, then providing for a relaxing of the constraint, and a repetition of the query. 

1 11. The article of manufacture of claim 10 wherein the embodied computer program 

2 causes the computer system to execute the method step of identifying a portion of the 

3 computer program code as a candidate for re-implementation as a database stored procedure 

4 call. 
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1 12. The article of manufacture of claim 1 1 wherein the query searches the database for a 

2 portion of the computer program code having static information indicating that the portion of 

3 the computer program code contains a call to a database management system, and having 

4 dynamic information indicating that the portion of the computer program code is subject to a 

5 call by another portion of computer program code. 

1 13. The article of manufacture of claim 12 wherein the query searches the database for a 

2 portion of the computer program code having static information indicating that the portion of 

3 the computer program code contains a number, above a specified first threshold, of calls to a 

4 database management system, and having dynamic information indicating that the portion of 

5 the computer program code is subject to a number of calls, above a specified second threshold, 
(jg by another portion of computer program code. 

kd 14. The article of manufacture of claim 10 wherein the embodied computer program 

T ? causes the computer system to execute the method step of identifying a portion of the 

13 computer program code as a candidate for re-implementation as a Web-enabling interface call. 

ffi 15. The article of manufacture of claim 14 wherein the query searches the database for a 

2 portion of the computer program code having static information indicating that the portion of 

3 the computer program code contains a transaction call. 

1 16. The article of manufacture of claim 15 wherein the query also searches the database for 

2 a portion of the computer program code having static information indicating that the portion of 

3 the computer program does not contain screen output related program code. 
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1 17. A computer system for identifying a portion of computer program code as a candidate 

2 for a modification, said computer system comprising : 

3 a parser for scanning and parsing source code corresponding to the computer 

4 program code to determine static information concerning the computer program code; 

5 an execution monitor for collecting dynamic information concerning the 

6 computer program code during an execution of the computer program code; 

7 relationships and dependencies developed responsive to the static information 

8 and dynamic information; 

9 a database for storing the static information, the dynamic information, and the 

10 relationships and dependencies; and 

1 1 a query of the database to produce a set of potential candidates of computer 

12 program code meeting a constraint of the query. 

1 II] 18. The computer system of claim 17 wherein if insufficient candidates are returned by the 

2^1 query, then providing for a relaxing of the constraint, and a repetition of the query. 

1 ^ 19. The computer system of claim 18 further comprising an identification of a portion of 

2'~£ the computer program code as a candidate for re-implementation as a database stored procedure 

3 0 call. 

1 20. The computer system of claim 19 wherein the query searches the database for a portion 

2 of the computer program code having static information indicating that the portion of the 

3 computer program code contains a call to a database management system, and having dynamic 

4 information indicating that the portion of the computer program code is subject to a call by 

5 another portion of computer program code. 
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21 . The computer system of claim 20 wherein the query searches the database for a portion 
of the computer program code having static information indicating that the portion of the 
computer program code contains a number, above a specified first threshold, of calls to a 
database management system, and having dynamic information indicating that the portion of 
the computer program code is subject to a number of calls, above a specified second threshold, 
by another portion of computer program code. 

22. The computer system of claim 18 further comprising an identification of a portion of 
the computer program code as a candidate for re-implementation as a Web-enabling interface 
call. 

23. The computer system of claim 22 wherein the query searches the database for a portion 
of the computer program code having static information indicating that the portion of the 
computer program code contains a transaction call. 

24. The computer system of claim 23 wherein the query also searches the database for a 
portion of the computer program code having static information indicating that the portion of 
the computer program does not contain screen output related program code. 



STL9-2000-0080US1 



22 



i ABSTRACT 

2 

3 METHOD OF, SYSTEM FOR, AND COMPUTER PROGRAM PRODUCT FOR 

4 PROVIDING AUTOMATIC IDENTIFICATION OF A COMPUTER PROGRAM 

5 CODE CANDIDATE FOR WEB DEPLOYMENT OR A STORED PROCEDURE 

6 

7 Computer program code which is a candidate for Web enablement or stored procedures 

8 is identified. Source code corresponding to computer program code is scanned and parsed to 

9 determine static information concerning the computer program code. The static information is 

I o stored in a database. Dynamic information concerning the computer program code during an 

II execution of the computer program code is also collected and stored in the database. 
12 Responsive to the static information and dynamic information stored in the database, 

13'S relationships and dependencies are then developed and stored in the database. The database 

may then be queried to produce a set of potential candidates of computer program code meeting 

lSlj a constraint of the query. If insufficient candidates are returned by the query, then the query 

1 £1 constraint may be relaxed, and the query repeated. A candidate for re-implementation as a 
17^J database stored procedure call may be identified by a query searching the database for a 

1 8p portion of the computer program code having static information indicating that the portion of 

i£?[ the computer program code contains a number, above a specified first threshold, of calls to a 

2 0 database management system, and having dynamic information indicating that the portion of 
2iQ the computer program code is subject to a number of calls, above a specified second threshold, 
22 by another portion of computer program code. A candidate for re-implementation as a Web- 

2 3 enabling interface call may be identified by a query searching the database for a portion of the 

2 4 computer program code having static information indicating that the portion of the computer 

2 5 program contains a transaction and does not contain screen output related program code. 
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As a below named inventor, I hereby declare that: 



My residence, post office address and citizenship are as stated below next to my name; 

I believe I am the original, first and sole inventor (if only one name is listed below) or an 
original, first and joint inventor (if plural names are listed below) of the subject matter which is 
claimed and for which a patent is sought on the invention entitled 

Method of. System for, and Computer Program Product for Providing Autom atic Identification of a 
Computer Program Code Candidate for Web Deployment or a Stored Procedure 



the specification of which {check one) 



is attached hereto, 
was filed on 



as Application Serial No. 

and was amended on (if applicable) . 

I hereby state that I have reviewed and understand the contents of the above identified specification, 
including the claims, as amended by any amendment referred to above. 

I acknowledge the duty to disclose information which is material to patentability as defined in Title 
37/!?Code of Federal Regulations, Section 1.56. 

I lireby claim foreign priority benefits under Title 35, United States Code, Section 119 (a) -(d) or 
Section 365(b) of any foreign application { s ) for patent or inventor's certificate, or Section 365(a) 
of "any PCT International application which designated at least one country other than the United 
StSJes, listed below and have also identified below any foreign application for patent or _ inventor ' s 
certificate or PCT International application having a filing date before that of the application on 
which priority is claimed: 

Prpdr Foreign Application ( s ) Priority Claimed 

55 None Yes No 

O (Number) (Country) (Day/Month/ Year Filed) 

I IMreby claim the benefit under Title 35, United States Code, Section 12 0 of any United States 
application (s) or Section 365(c) of any PCT International application designating the United States, 
li'ated below and, insofar as the subject matter of each of the claims of this application is not 
disclosed in the prior United States or PCT International application in the manner provided by the 
fiSSt paragraph of Title 35, United States Code, Section 112, I acknowledge the duty to disclose 
information which is material to patentability as defined in Title 37, Code of Federal Regulations, 
Section 1.56, which occurred between the filing date of the prior application and the national or PCT 
international filing date of this application: 



(Application Serial No.) (Filing Date) (Status) (patented, pending, abandoned) 

I hereby declare that all statements made herein of my own knowledge are true and that all statements 
made on information and belief are believed to be true; and further that these statements were made 
with the knowledge that willful false statements and the like so made are punishable by fine ° r 
imprisonment, or both, under Section 1001 of Title 18 of the United States Code and that such willful 
false statements may jeopardize the validity of the application or any patent issued thereon. 
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POWER OF ATTORNEY: As a named inventor, I hereby appoint the following attorney (s) and/or agent (s) 
prosecute this application and transact all business in the Patent and Trademark Office connected 
therewith. (list name and registration number) 

Romualdas Strimaitis (#35,697) Christopher A, Hughes <#26 # 914) 

Timothy M. Farrell (#37,321) Edward A. Pennington (#32,588) 

Ingrid M* Foerster (#36,511) John E. Hoel (#26,279) 

Prentiss W. Johnson (# 33,123) Joseph C. Redmond, Jr. (#18,753) 



Send correspondence to: 



Prentiss Wayne Johnson 

Attorney 

IBM Corporation 

Intellectual Property Law 

555 Bailey Avenue (J46/G467) 

San Jose CA 95141-1003 



Direct Telephone Calls to: (name and telephone number) Prentiss W. Johnson, 408-463-5673 



Full name of sole or first joint -inventor: Curt L. Cotner 



Inventor's signature: 



Date: 



Residence: 1975 Day Road, Gilroy, California 95020 



Citizenship: United States of America 



Post Office Address: Same 



Ful^l name of second joint -inventor: Laurence E. England 



Inventor ' s s ignatur e : 



Date: 



Residence: 520 La Canada Court, Morgan Hill, California 95037 



Citizenship: United States of America 



Post Office Address: Same 



Full name of third joint -inventor: Howard J. Glaser 



Inventor ' s s ignatur e : 



Date : 



Residence: 5808 Vargas Court, San Jose, California 95120 



Citizenship: United States 



Post Office Address: Same 
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